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® A method for creating online infonnalion from the same marked-iip source materiai used to create printed 
infonnation such as a word processor or a marlc-up language source use with a text formatter. A booic data 
stream is provided. In a new intermecflate fonnat for storing online information, speciflcaily designed to be used 
by a book display program. This data stream captures and preserves stmctural infonnation about books. It is 
uniquely suited to display onEne books in a very usable manner on a variety of display devices. Also provided is 
a new kind of program, (a book di^lay program) for manipulating the book data stream, and allowing users to 
interact with the onfine infonnalion. A distinguishing characteristic of the book display program is its use of the 
metaphor of a hard copy book on the display screen. H lets readers treat online books like hard copy books. 
This program uses the book data stream (descnl^ed above) as its input 
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METHOD FOR DISPLAYING ONUNE INFORMATION 
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The present invention relates generally to the use of computers for displaying information and more 
particularly to a method for displaying data in a book like format for use on-line. 

Creating, maintaining, and reading online information has long presented problems for both the authors 

and the readers of online Information. . . 

The invention makes online infom^ation easier to aeate and maintain since it accepts existing 
information formats, and requires only the application of existing author skills and techniques used for 
creating printed books. It also makes online information more usable than ever before by implementing the 
hard copy metaphor more completely than has been done previously. 

Current techniques for creating online information result in information that is hard to use for reading 
and referencing. The prior art attempts to overcome this by requiring a lot of manual labor to create and 

maintain the online information. 

Prior art techniques also demand that authors learn skills that differ from those they already possess for 
creating printed information. Current techniques provide only a small range of reader function automatically, 
requiring authors to manually provide the full range of function for each piece of information they create. 
This makes it very expensive to keep the content of printed and online infomnation synchronized. This 
invention provides the full range of capability for the reader based on the original printer-specified input, 
without manual intervention by authors. This makes it possible for authors to produce highly usable online 
information from exactly the same source material used to produce the printed information, without having 
to learn new skills. Current techniques involve (1) creating separate hand-crafted versions of the text tor 
online viewing, (2) displaying the text on terminals monolithically with no provision for navigation, or (3) 
making tiie text available under clear-text browsers, with only primitive navigation functions- 
Prior art techniques require that readers of online information think about and interact with the 
information in a new way. This invention allows readers to think about and interact with the information just 
as they do with printed books. Readers can use this invention to read online books, make margin notes, 
leave bookmarks, and use many other familiar techniques learned for using printed books. 

In accordance with a preferred but nonetheless illustrative embodiment demonstrating objects and 
features of the present invention there is provided a novel method for creating online information. 

This invention creates online information from the same marked-up source material used to create 
printed information such as a word processor or a markup language source file used with a text formatter. 

The invention also provides a book data stream, m a new intermediate format for stonng online 
information, specifically designed to be used by a book display program. This data stream is a rneam of 
capturing and preserving structural informatfon about books. It is uniquely suited to display online books in 
a very usable manner on a variety of display devices. t_ ^ * 

Also provided is a new kind of program, (a book display program) for manipulating the book d^ 
stream and allowing users to interact with the online information. A distinguishing charactenstic of the book 
display program is its use of the metaphor of a hard copy book on the display screen. It lets readers freat 
online books much more like hard copy books than was previously possible. This program uses the book 

data stream (descrit»ed above) as its input. . ■ ♦ 

It is thus an object of the invention to provide a method for creating an online book for viewing at a 

40 computer terminal. . , . . ^ 

It is a further object to provide a method for creating an online book using source developed tor a 

printed version of the book with little or no additional woric 

It is still another object to provide a method for displaying an online book that offers all the hinction a 

reader obtains from a hardcopy version of the book. 

It is yet another object to provide a book display program for displaying a book online that preserves 
the author's printed formatting intent in a version for use on a computer terminal. 

These and other objects, advantages and features vrill become more apparent upon reference to the 

following description and the annexed drawings. 

FIG. 1 shows the general method for creating online book files according to the present invention; 
RG. 2 shows the genera! method for reading onRne books according to the present invention; 
FIG- 3 shows an example of control sequence processing; 
RG. 4 shovre an example of t>ackspace processing; 
RGs. 5A and SB show the structure of variable length string data structures; 
RG- 6 shows the text phase variable length data structure; 
RG 7 is a hiearchial Input output diagram of the store picture phase; 
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FIG- 8 \s flow chart describing the store picture phase; 

FIG. 9 schematically illustrates picture phase buffer handling; 

FIG. 10 shows a detailed illustration of the picture phase information in a book file; 

FIG. 1 1 shows the structure of a complete book file; 

FIG. 12 shows an example of a display screen obtained using the present invention; 
FIG. 13 is a hiearchial input output diagram of the display picture phase; 
RG. 14 is a flow chart describing the display picture phase; 

BG. 15 shows an example of a display screen having a window, obtained using the present 
invention. 



DESCRIPTION OF A PREFERRED EMBODIMENTS 



IS The implementation of the invention is described in two phases: 
. Creating an online book 
. Reading an online book 

In the description of the preferred embodiment frequent reference will be made to markup and 
Generalized Markup Unguage (GML). In general, and as used herein, markup is infomnation added to a 
document that enables a person or a system to process it. In the IBM product known as SCRIPT, the 
markup consists of GML (generalized markup language) tags, control words, macros and symbols. GML is a 
language used to identify the elements of a source document without respect to specific formatting. IBM's 
product known as GML is an example of such a language. ISO standard SGML is another example. 

All static processing is performed when the wiline books are created. Dynamic processing cannot be 
25 done until the book is displayed. An example of dynamic processing is deciding which colors to use to 
display highlighted text. This processing is dependent on the colors available on the display device used to 
display the book. 

In order to provide a useful and accurate analog to a hardcopy book the present invention uses three 
elements of the source (i.e the marked-up. or word processor expression of the material) that are important 

30 to providing a rich book reading environment 

1. the fundamental hierarchical structure of the book (sections, subsections, paragraphs, etc.). 
2- ttie information itself (text, as well as graphics and image pictures). 
3. the author's presentatton intention (high-lighting, indenting, spacing, etc.) . 
An example of the mariced up expression is the product of International Business Machines. Corp., GML 
35 (Generalized Mark Up Unguage) that allows a writer to insert :hp1.tags:ehp1. into the text. These tags serve 
as instructions used by a text formatting program that indicate how specified portions of text are to be 
presented on the printed page, tor example, underiined, italicized, centered, etc. 

In all cases, what is captured is in generic intention form. Rather than converting the GML source to a 
directly displayable or printable data stream, this invention converts it to an internal form of intent-based 
40 indicators and flags. An easy-to-prog ram representation of the markup intention is stored. 

In this way. the intents expressed in GML are preserved in a more programmable form after all the 
basic text processing functions of the text formatter are completed- Said another way, the author organized 
the book in the way he thought useful. This invention captures and takes advantage of that organization 
(structure, presentaUon intent, and infomiation) to provide useful ways for readers to navigate through the 
4S material. 

The book display program, given the two-dimensional nature of the display saeen, uses the structural 
information preserved in the book file to provide convenient forms of navigation that are metaphorically 
related to the (three-dimensional) methods of navigation in printed books, (i e., page turning, table-of- 
contents based navigation, subject headings, etc). It also allows for other metaphoric actions on the online 
sn infnrmfltinn. such as addino oersonal annotations similar to margin notes on a printed page. 



CREATING AN ONUNE BOOK 



The foUowing description includes reference keys (in parentheses) to RG. 1 and FIG. ^ 
Refer now to RG. 1 in which the book building phase of ttie present invention is shown. The source 
document file containing the source material 10 is the same source file used to create a printed document 
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Text formatter 20 reads the source material 10 and uses the markup definitions 30. as further described 
below to generate the formatted test stream 40. Text fonnatter 30 is a formatter such as IBM's Document 
Composition Facility (DCF). or any program that performs the same processing. Invocation of the book 
building phase includes a capability to specHy the name of the program to be invoked here. The scope of 

5 this invention is not limited to IBM's implementation of a text fomr>atter. Any text formatter that accepts any 
kind of markup language could be used. 

Markup definitions 30 for online books contain descriptions, in the language of the text formatter, for 
how some processing differs for an online book. This inventton disctosure covers the adaptation of the 
markup definition mechanism to the specific definition required to produce online books, rather than printed 

w books. Broad coverage of the markup languages allows most books to be created with little, if any. editing 
re- work. 

The formatted text stream 40 generated from the text formatting step 20 is uniquely suited for use as 
the basis of the book data stream, described below. 

Markers are placed in text stream 40 for later processing by post processor 50. Many of the capabilities 
75 externalized by the book display program are made possible by the information about book structure and 

presentation intention that is captured at this stage. 

Post processor 50 has two phases that create the online book file. One phase processes text: the other 
processes pictures and other graphics. Post processor 50 perfonns several operations, including: 
. Preserves information about the structure of the book, for navigation within the book under the book 
20 reading program. For example, does the book have front matter and back matter? Where is the table of 
contents? 

. Preserves data about the intent of various forms of 6ML markup. This mal<es it possible for the book 
display program to map the markup to the specific capabilities of individual display devices. 
. Includes graphic pictures in the book. 
25 . Incorporates any ancillary files required by graphics pictures (such as symbol sets). 
. Includes scanned image pictures in the book. 

The current implementation of the invention could be extended to include digitized voice or other audio 

segments, digitized video segments, and digitized animation sequences. 

Post processor 50 receives the formatted text data stream 40 and converts it to bock data stream 60. 
30 Book data stream 60 is not bound to a specific display device type until the moment of display and. as will 
be described hereinbe!ow» Is uniquely suited to the demands of displaying online information. 

Post processor 50 inserts special control codes in book data stream 60 that identify the structural 
elements of a book (topics, table of contents, index entries, figure list) and preserve the intentional aspects 
of text highlighting, rather than merely the representational aspects. 

35 The Indexer/Compressor 70, an example of which is described in copending application serial number 
XXX.XXK " Method for Use of Morphological Information to Cross Reference Keywords Used for 
Infonnation Retrieval." and assigned to the assignee of the present invention, converts the book into as 
small a file as possible. It also creates indexing and linguistic information, so that the online book may be 
searched in a variety of ways. The compression of the book into a small file is not absolutely necessary to 

40 the purposes of this invention. Compression is a functk>n known to be required by potential users of this 
invention, due to the storage requirements of large numbers of online books. K a compressor is used at this 
stage, then the book display program must have available a program with complementary function; that is, a 
decompression program that will decompress the individual records of the book when they are needed. 
The book file created is stored on disk at step 80. Metaphorically, this is equivalent to a printed copy of 

45 a book that has been made available on a lending-library shelf. It may be read or used any number of times 
by any number of people. 

Post processor 50 in its second or picture phase 50A incorporates Picture file 51 and 53, and symbol 
files 52 into the book file 80 that is stored on a disk or other non-volatile storage device. 

FIG. 2 schematically illustrates the process for displaying a book from the stored book file 80. The book 
50 display program is used to display the book file on a display device of the end-user's choosing. 

Book display program 90 is later used to display the book file 80 on a display device of the end-user's 
choosing. The book display program 90 recognizes the book data stream 60 and converts it to a usable on- 
screen display of a book 130. At that time, ail text highlighting controls are interpreted so as to capitalize on 
the characteristics of the display 100. producing brightening, color changes, or underscoring as appropriate. 
55 The book display program 90 uses information embedded in the book about its structure and organization 
together with other intention information gleaned from the maricup. The book display program 90 formats 
the book for the reader, a screen at a time. Also, as discussed further Ijelow book display program 90 also 
takes into account information about the user's place in tt» book 1 10, when generating a screen for display. 
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The book display program understands structural elements of books and so is capable of producing an 
effect similar to page-by-page reading. It can respond to a rich set of commands designed to accommodate 
the requiremems of readers of books, such as- show the table of contents, show the index, go directly to 
topic X The book display program provides a variety of linguisticaHy-based searching functions and aiso 
5 can allow direct on-screen annotation similar to margin notes in a hard copy book 1 50. These annotations 

are stored separately from the book file. 

The book display program also provides for several kinds of place saving and context intenrogadon. as 

well as the ability to close the book and leave a bookmark 140. 

Two concepts are central to the present invention, namely, that of a topic and a technique for captunng 
10 information in the source document, called control sequences. 

Just as a printed book uses a page number as its unit of reference, an online book uses a topic. A topic 
consists of a GML heading tag and the information that follows it. up to the next heading. 

The invention doesnt use page numbers because the sizes of display screens vary widely (24 lines to 
60 lines or more). Page 27 on one display might be page 12 on another, so a unit of reference is u^ed that 

J5 is consistent on all displays. 

Online topics are used like printed pages. The table of contents of an online book lists the headings 
with their topic identifiers, just as they are listed with page numbers in a printed book. 

A topic identifier is usually a number (such as 1 2). but occasionally it is a word (INDEX, for example). 
Generally, front and back matter tags (such as .PREFACE and :INDEX) are given words to identify them. 
20 and tags in the body are given numbers, like heading numbers in print. A topic identifier is shown wherever 

a page number is shown in print. 

A book may use a reference tag. like this one: 
See : Heading id "furinfo" unknown for more details. 

When the book is printed, the page number and text for the heading named "furinfo" are inserted, like 

25 so: 

See "Further Information" on page 37 for more details. 

From the same markup, the invention produces a topic reference instead of a page reference, like this: 
See "Further Information" in topic 5.0 for more details. 

Topics are created by headirigs tags (:H1-:H6). Normally. :H1 through :H4 create topics, while others 
30 do not but instead are treated as part of the information of the topic they're in. 

A topic can have subtopics; this happens when it is followed by headings at the next level. For 
example, a book with three :H2 tags after its first :H1 tag gets its :H1 heading numbered 1.0 and its :H2 
headings numbered 1.1. 1-2. and 1.3 - they are subtopics of 1.0. \Amen the online book is displayed, these 
subtopics are shown in a topic list at the end of the information in topic 1.0. like so: 
35 1 .1 The Rrst Head 2 

1 2 The Second Head 2 

1 .3 The Third Head 2 . 
Vymen a topic identifier is assigned, it's usually the same number as the heading number assigned in 

print, although the current implementation has a few exceptions. 
40 A TOPICID attribute is also provided to pennit the author to manually assign topic numbers when 

necessary or desirable. , 

The aforementioned control sequence is the name of the technique invented to capture infonnation from 

GML source file 10 and store it in book data stream 60 for later use by the book display program 90. 

Control sequences are generated by the (Vlariuip definitions 30. They detect the usage of a tag. DCF 
45 control word, or other infonnation in the GML source document 10 and record that usage in the formatted 

text stream 40. The Post processor 50 converts control sequences into control records in the fckook data 

stream 60. These control records are processed dynamically by the book display program 90. 

For example, there is a DCF control word called .PA (Page Eject) that causes text to be placed on a 

new page. Since the book display program 90 must dynami cally format the book for display devices of 
50 different sizes, the only way to perform a page eject is to mark the place in the text where the page eject 

should occur, so that the book display program 90 can fomial the subsequent text on a new screen. The 

spot is marked using a control sequertce. 

RG. 3 graphically illustrates how the process works. The source file 10. in this instance contains the 
.PA control word. The markup definition 30 for the DCF .PA control word captures the string ".PA" in a 
55 control sequence in the fonnatted text stream 40 generated by text formatter 20. The text fomiatter inserts 
the codes ESC and END around the PA control word. The Post processor 50 converts the PA control 
sequence into the PA control record in the book data stream 60. so that the presence of the control word 
nA -.rwH/^otoH hu r. DA wKon fHo nnHno hnntc is disolaved bv the t^ook disolay program 90. 
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panels 1 and 2 (131 and 132. respectively) are generated, such that the control record for PA is used to 
determine that subsequent information starts on a new screen. 

Each control sequence starts with an escape sequence, a series of characters that won't occur in 
ordinary text. Next the control sequence contains the information to be captured. Rnalty. another escape 
5 sequence signifies the end of the control sequence. Here's how a control sequence might appear for the 
DCF control word that skips a space before the next text line (.SK 1): 
ESC.sk 1END 

In the example, the characters "ESC~ represent the starting escape sequence, and "END" represent 
the ending escape sequence. These escape sequences are actually implemented as strings of unusual 

10 unprintable characters. 

Control sequences are inserted into the formatted text stream 40 using the string form of the DCF .OC 
control word. This technique ensures that the formatting of regular text output is not affected when the 
control sequences are removed by the Post processor 50. 

The creation of an onBne book is now described. The online books are created from files marked up 
75 with 6ML, but as discussed above any program, such as a word processor, that inserts formatting tags into 
the text could be used to create the source, although appropriate changes in subsequent processing will be 
required. 

The text in the online book is created in the same manner as text is created for printed books. The 
cun-ent implementation of the invention uses Generalized Markup Language (GML) source files, but the 
20 implementation can be extended to other word processing source files. A sample source file is shown in 
Example 1 . 

Authors who have existing GML source files can put them online with little or no changes, using this 
invention. If changes are made, they are made for one of two reasons: 

1 . To avoid a restriction of the current implementation of the invention. 
25 2. To enhance the online information using techniques unavailable in print. 

There are not many restrictions that require changes to the author's source files, but here are the 

common ones: 

1 . markup that assumes page layouts (such as a grid-rGRID). 

2. markup that assumes page numbers (such as a manually constructed table of contents- :TOC). 
30 3. tables too wide for a display screen (:TABLE). 

These restrictions are part of the preferred embodiment, although they could be removed by appro- 
priate changes to the emt>odiment. 

The second type of change, enhancing information with new online techniques, is optional. An author 

makes one of these changes only if he desires to: 
35 . Override the nonnal treatment of a heading tag. The author can use a new tag attribute, called TOPICSEU 
to cause a heading to create an online topic that normally would not. The attribute can also suppress 
aeation of a topic for a tag that otherwise would create a topic. 

- Select the topic identifier assigned to the topic for a heading tag. A new tag attribute, called TOPICID. 

allows the author to perfomi this function. 
40 Generally, source files used for printed information are used without change with this invention. 

The Text formatter 20 used in the preferred embodiment of this invention. IBM's Document Composi- 
tion Facility (DCF). processes GML markup using Markup definibons 30. These definitions already exist to 
process markup for printing. This invention modifies these existing definitions to produce online information. 
The defmition that controls all processing is called the profile. The other definitions are stored in macro 
45 libraries and are categorized according to the type of changes made. 

Applications that use DCF as a text formatter often use a DCF profile, which is a file processed by DCF 
before the document itself is formatted. A profile can contain frequently used symbol and macro definitions. 
GML processing functions, and controls for the formatting environment For more infonmation on how DCF 
uses profiles, or on how applications can use profiles with DCF. refer to the IBM publication Document 
so Composition Facility: Text Programmer's Guide (SH35-0069). 

The invention uses a new profile that creates the formatting environment and defines all of the other 
markup definitions-definitions that are changed ior onBne information, and those that are unchanged from 

print 

The formatting environment for online display is quite different from a printing environment In the 
55 preferred embodiment of the invention, the DCF page length is set to 3000, so that all topics fit on a single 
DCF page. The best solufion wouW be to use an infinite page length, but this is not currently supported by 
DCF, although otfier prodircts may support an infinite page length. 

The oreferred embodiment of the Invention sets the DCF line length (the width of the text) to 74. The 
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embodiment could be changed so that the text is not fomnatted to a specific (ength, so that it can be 
retlowed dynamically inside display windows of varying sizes. 

The preferred embodiment uses an IBM 2741 tennlnal as its DCF output device. This device was 

chosen for several reasons: 

. The 2741 can use OCRs overstrike capability to support a large number of fonts (typestyles). The profile 
defines each font used in markup definitions with a unique overstrike character. Later, the Post processor 50 
converts those overstrike sequences found in the formatted text stream 40 into font control records in the 
book data stream 60. Some examples of the fonts defined are shown in TABLE 1 . The FONTDEF record is 

described further below. . 
. The 2741 supports most of the same features as the 3270 terminal, which is the eventual output device for 
the preferred embodiment of the invention. It will be dear to those skilled in the art that the invention couW 
also be used in an intelligent workstation environment by using an all-points-addressabie DCF output device 
(using a PostScript data stream, for example) instead of a 2741 . 
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TABLE 1 



Kind of Text 



Character 



FONTDEF 
Identifier 



20 



CAUTION 



B 



CAUTION 



25 



30 



35 



40 



45 



SO 
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15 



20 



25 



30 



35 



40 



45 



:CAUTIONtext 


F 


CAUTIONTEXT 


:CIT 1 


C 


err I 


1 :DANGER | 


D 


DANGER 


1 :DANGERtext 1 


0 


DANGERTEXT 


1 :HP1 Y 


1 


HP1 


:HP2 1 


2 


HP2 . ] 


1 :HP3 


3 


HPS J 


1 :HP4 1 


4 


1 HP4 1 


1 :HP5 1 


5 


1 1 


1 :HP6 


6 


HP6 


1 :HP7 1 


7 


HP7 J 


1 HPS 


8 


HPS ~] 


1 HPS 1 


9 


HP9 


1 :H0 


0 


HO 1 


1 :H1 


H 


H1 


1 82 


1 


H2 [ 


:H3 T 


J 


H3 1 


1 :H4 1 


K 


H4 1 


1 :H5 j 


L 


H5 1 


:H6 [ 


M 


H6 [ 


1 :PK 1 


P 


1 PK I 


1 :PK with DEF attribute 1 


Q 


PKDEF 1 


1 PV 1 


V 


PV 1 


1 :PV with DEF attribute 1 


Z 


PVDEF 1 


1 1 


R 


1 1 


1 '"^ 1 


T 


1 ^ 1 


1 :WARNING 1 


W 


WARNING 1 


1 :WARNlNGtext i 


G 


WARNINGTEXT 


1 :XMP 1 


E 


1 XMP j 


:XPH I 


X 


XPH 1 


1 underscoring | 
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The profile also defines the processing that markup should undergo. This processing is included in 
Markup definitions 30. While some markup definitions for printed output did not need to be modified, many 
others had to be changed for the invention. Some examples of the modified definitions are described father 
below A profile shoukJ include definitions for all markup in the markup language. The preferred embodi- 
ment of the invention supports IBM's Starter Set GML (part of IBM's DCF product) and IBM's BookMaster 
GML (a separate IBM product), but the implementation can be extended to any markup language or word 
processor (For more information on Starter Set GMU refer to ttie IBM publication Document Composition 
Facility: Generalized Markup Language Starter Set Reference (SH20-9187). See the IBM pubftcation called 
IBM Publishing Systems BookMaster User's Guide (SC34-5009) for more informaUon on the BookMaster 
markup language.) 
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AppKcations that use DCF as a text formatter often use maao libraries, i.e. files that contain DCF 
macros used to format the source document A maao library can contain frequently used symbol and 
macro definitions. The macros can be used to override DCF control words and to process 6ML markup. For 
more information on how DCF uses macro libraries, or on how applications can use macro nbraries with 
DCF. refer to the IBM manual Document Composition Facility: Text Programmer's Guide (SH35-0069). 

All Markup definitions 30 invoke DCF control words to accomplish their processing. Some of these 
control words are intercepted by macros (stored in the invention's macro library) that change the behavior 
of these control words. In the present invention, control is changed according to the functions, described 
herein, needed to accomplish an online t)00k metaphor. 

Any Markup definition 30 that uses a DCF control word listed in TABLE 2 will invoke a macro instead of 

the control word. 
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Macro 
Name 



KO 



HI 



H2 



PA 
PI 



RF 



SK 



TC 



TABLE 2 



Description 



Insert .CP control sequence 



Force usage of 3270 API. characters for all rules 



Create a topic 



Create a topic 



Create a topic 
Create a topic 
Create a topic 



Create a topic 
Create a topic 
Format index entry record 
Format index and insert INDEX control sequence 
Insert .PA control sequerK:e 
Replace page number with topic identifier 
Suppress all footers 



Suppress all headers 

Generate PICTURE instructions, store picture name, and insert PIC control sequence 



Insert .SK control sequence 



Format table of contents and insert TOC control sequence 



The following describes generally, examples of some of the modified definitions, which may be invoked 
by the usage of macros. In the description that follows, the modified markup definitions are listed and 
described by category. 



55 



1 . MARKUP THAT CREATES A TOPIC; 

Many Markup definitions 30 have been modified to aeate topics. Some of the tags that can create 

topics are: 

a Headings (:H0-6) 

b. Front matter headings (:PREFACE. :TOC. :ABSTRACT. etc.) 

r Other front matter sections that donH create printed headings (.TTTLEP. :SYN0PSIS. :NOTlCES, 
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70 



30 



45 



etc.) 

d. Back matter headings (:INDEK iBIBLlOG, rGLOSSARY, etc.) 

e. Message numbers (:MSGNO) 

Topics are created by inserting control sequences ttiat capture: 

a. The name of the tag (HDLEVEL) 

b. The topic identifier of the topic (TOPIC) 

c. The name of the SCRIPT source lile (SOURCEFN) 

These control sequences are processed by the Post processor 50 into topic control records. 



50 
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2. MARKUP THAT REFERS TO TOPICS: 



Some Markup definitions 30 have been modified to refer to topic identifiers instead of page numbers 
(as they do in print). Some of the tags that refer to topic identifiers are: 
IS a. References to headings (:HDREF). 

b. References to figures (:RGREF). 

c. Table of Contents (:TOC). 

d. Figure List (:FIGLIST). 

The markup definitions for these tags have been modified so that the topic identifier is produced 
20 instead of the page number that would be generated for the printed document. 

The above will be more fully understood by reference to the following example. A book may use a 

reference tag. like this one: 

See - Heading id "furinfo" unknown - for more details. 

When the book is printed. IX^F inserts the page number and text for the heading named "furinfo" tike 

25 so: 

See "Further Information" on page 34 for more details. 

From the same markup, the present invention produces a topic reference instead of a page reference. 

like this: 

See "Further Information" in topic 5.0 for more details. 



3. MARKUP THAT CREATES INDEXES: 

Some Markup definitions 30 have been modified to create online subject indexes in the back of an 
35 online book. Some of the tags that produce an index are: 

a. Index (:INDEX). 

b. Index entry (:l1-3). 

c. Index heading (:IHl-3). 

The markup definitions for these tags have been modified so that 
40 a. the content of index entries are captured in PI control sequences processed by the Post Processor 

50 into search index control records in the book data stream 60. 

b. topic identifiers are substituted for page numl^ers in the index. 

c. the index can be dynamically formatted into two columns when displayed. 



4. MARKUP THAT DESCRIBES THE ENTIRE DOCUMENT: 

Some Markup definitions 30 have been modified to save inform 
of the tags that supply this information are: 

a. Trtle page information-document title, author name, etc. {:T 

b. Security level and copyright notice (:GDOC. rUSERDOC. el 

c. Leader dots in lists {:DOCPROF). 

This infonnatton is copied by the Post processor 50 into header 

60. 



5. MARKUP WITH MODIFIED FORMATTING: 
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Some Markup definitions 30 were modified so that they produce better results online. Since the 
formatting environment in the imptementation of this invention is so different from a print for^^atting 
environment some definitions required some fine tuning. 

Some examples of tags whose definitions were changed for formatting reasons are: 

a. Change spacing on cover page (:COVER). 

b. Use 3270 hexadecimal codes for character graphics (iCGRAPHIC). 

c. Suppress multipart figure captions {:FIGCAP). 

It will be understood by those skilled in the art that other formatting languages, and or word processors 

may require different modifications. 

The formatted text stream 40 produced by the text formatter 20 using the Markup definitions 30 is 
converted to tiie book data stream 60 by the first phase ot the post processor 50. A second phase of the 
Post processor 50 also Includes graphics and image pictures in the book file 80 and includes uncompres- 
sed security and copyright rwtices. 

The first phase of the post processor 50 converts the text into a record-oriented file that is suitable for 
the Indexer/Compressor 70 called tiie book data stream 60. This design allows other word processing 
formats (besides DCF-based GML) to be used with the invention. Any word processor file can be processed 
to the book data stream 60 described here. The preferred embodiment converts a DCF GML source file. 

In the preferred embodiment the Post processor 50 takes two passes over Oie fonnnatted text stream 40. 
The Post processor 50 performs three main functions in the first pass: 

1. Processes 

Header Control Records are created directly by the profile of the Mari<up definitions 30. Most of these 
records are written directly into the book data stream 60 file by the Post processor 50. and are described 
further below. Some records are used directiy by the Post processor 50. however, and descriptions of 
which, follow: 

STARTCTL: the three characters tiiat signify ttie start of a control sequence. 
ENDCTLj the three characters that signify the end of a control sequence. 
BACKSPACE: the character used as a backspace character by text formatter 20. 



2. Detects the topic structure. 

During the first pass, the Post processor 50 detects the structure of the topic containing the list of all 
topics and their subtopics. During tiie second pass, ttiis information is used to create the menu and topic 
control records. 

3. Creates topic summary control records. 

During the first pass, the Post processor 50 creates topic summary control records. These records 
"summarize" the formatting control records and text lines in the topic. The records are written to a 
temporary file during the first pass, and read back in during ttie second pass. 

The Post processor 50 performs several other functions in tiie second pass: 

1 . Processes control sequer>ces. 

There are several control sequences that are processed by tiie Post processor 50: 
FORMATTING: Formatting control sequences are processed into fonriatting control records in tiie inter- 
change file. These include PIC (picture prompt) and several DCF control words (.CP, .PA. .SK. and .SP). 
INDEX: There are two index control sequences 1) INDEX which signifies tiie start of the index, and 2) PI, 
which indicates in tite text an index entry to be referred to in tiie index. 

CONTENTS: The TOG control sequence indicates ttia! the table of contents control records (stored in a 
separate file by the .TC markup definition) shouW be inserted at that point 

TOPIC: There are three topic control sequences which always appear together at the start ot a new topic: 
a. HDLEVEL contains the tag or control word tiiat created ttiis topic. The HDLEVEL topic control 
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record is created from this control sequerwie. ^ . » . -rk« 

b. SOURCEFN contains the filename of the SCRIPT source file that created this topic. The 

SOURCEFN topic control record is created from this control sequence. 

c TOPIC indicates that a topic starts at this point. If menu control records need to be generated for 
the previous topic, they are produced. Then, the topic control records for this topic are produced from the 
topic structure information gathered during the first pass. 

A diagram showing an example of control sequence processing was previously descnbed wrth respect 

to FIG. 3. 



30 



45 



2. Processes backspace characters. 



After all control sequences have been removed and processed, a record is processed for backspace 
characters. Backspace characters are used in the present invention to determine the font with which a 

15 character is to be displayed. j w « 

n text is overstruck by characters defined as font changes, then FONT control records are produced. It 
not. the text is repositioned according to the number of backspaces and the backspaces are removed. 

Refer now to FIG. 5 which showsa diagram of backspace processing. In the example descnbed. the 
source file contains the phrase "book file: surrounded by :hp1. and :ehp1.. These tags delimit a word to be 

20 highlighted, somehow, ordinarily underlined in a printed document. The markup definition 30 in this 
instance, contains the markup definition for &gmLhp1. which causes use of of font Hll for text defined m the 
markup definitions 30 to be overstruck by a "r. Thus the formatted data stream at 40 contains the phrase 
"book////1 1 1 1 file////". The post processor 50 changes the backspace characters "/" into the appropnate 
codes in book data stream 60. Thus the control codes CFONT 1 4 1 and CFONT 6 4 1 are inserted pnor to 

25 the words "book file" in book data stream 60. (FONT control records are further described below), where 
the first arguments after the FONT control record (1 and 6) indicate the start column, the second arguments 
(4 and 4) indicate the length, and the third argunoent (1 and 1) indicate the font to be displayed. The result, 
shown at 135 includes the phrase "book file" underlined on the display. 
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3. Processes text. 



Text Records: After all control sequences and backspaces have been processed, what remains in the 
input record is the normal text that wouW ofhenflfise have been printed. A text record is produced from this 

35 remaining text. ^ . »_. • ,u 

One of the more compBcated functions of the Post processor 50 is its handling of variable length 
strings Variable length strings are groups of data of different lengths. Variable length strings are important 
to the present invention because they permit the present invention to build up infonnaton about different 
items For example, the summary control records are constructed from various items, and the total size of 

40 the record is not known beforehand. It is therefore important to be able to handle variable length stnngs in 
this, and other instances. Both the formatted text stream 40 and the book data stream 60 contain vanable 

length records. . ^„ „^ l. ^ 

The strings are held in a data structure called VARI v«rhich is shown in FIGs. 5A and 5B. RG. 5A shows 
a one-block string, or the structure of the string upon initialization. The string structure a pointer to the first 
block 200 and a pointer to the last block 201 . Both 200 and 201 point the beginning address of the pointer 
to the next block. The string structure also contains a pointer to the previous block 203. which in the case of 
a one block string does not point any where. The length of such a string 204 is 0. The data in the stnng is 

indicated at 205. ^ 

FIG 5B shov;^ the structure of a string having three 4096-byte blocks 205. 206 and 207. Once again. 

the string structure includes a pointer 200 to the first block and a pointer 201 to the last btock of the stnng. 
The pointer to the first block points to the beginning address of 210 in bkx:k 205 which in turn points to the 
starting address of block 208 containing pointer 214, which in tum points to the start of the address of block 
207 containing pointer 220. Pointer to last bkxA 201 ateo points to the starting address of block 207. since 
this wouW be the last block. Also, each block contains a pointer to the previous block. Pointer 21 1 does not 
point to a previous block, because the btock it is contained in. 205 is the first block. Pointer 215 points to 
block 2(© as the previous block, and pointer 221 points block 206 as its previous block. Each btock also 
contains information as to its length (212. 216 and 222) and of course, the data it holds (213. 217. and 223). 
In thA nrf^<»rrt invention subroutines perform variable length string handling fuf\ctions of the foltov^ng 
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types: 

1 . Add data to the end of a string (chaining a new block if necessary). 

2. Initiafize pointers and the first block of a string. 

3. Clear the blocks containing a string by setting the length counters to zero. 

4. Concatenate two strings to create a third string. 

5. Release the storage acquired to hold a string. 

6. Return a portion of a string (substring). 

7. Return the length of a string. 

Some of the functions of the Post processor 50, such as detecting topic structure, requires the 
processing of lists of variable sizes, called variable length list handling. The lists are held in data structures 
called XE (for the data) and XEENTRY (for the offset into the data). The list items themselves are each 
variable length strings as previously explained. A diagram of the list data structure is shown in FIG. 6. The 
structure includes number of list items 220. the pointer to the offset table 221 and the pointer to the list data 
222, Pointer 221 points to 223. the XEENTRY structure which in turn contains a pointer to the data in in 
224. 

Subroutines perform variable length list handling functions: 

1. Add an index entry and list item. 

2. Return a list item. 

The second phase of the Post processor 50: 

1. Stores the copyright and security notices from the :GDOC or :USERDOC in the book file 80 (so 

they can be seen when the book file is browsed). 

2. Includes graphics and image pictures in the book file 80. 

3. Sets the number of 4K picture blocks in the txjok file 80. 

FIG. 7 is a Hierarchical Input Output (HlPO) diagram of the picture phase. A flowchart of the picture 
phase is depicted in FIG. 8. FIG. 7 shows processing that takes place in the picture phase. The names of 
the files PICTUREA, . . .PICTUREH are listed, the number of files to be processed. 8. being listed at top. 
Also as shown, there is a maricer indicating if the individual file is a graphics (G) or image (I) file. Several of 
the files, themsehms are shown at 301-304. SYMSETH 305 is a symbol set from which the graphics 
pictures may be constructed. The book file 308 is shown including various components, including the 
header/user data 310, picture directory 311. the pictures 312 themselves, the symbol sets 313 and the 
symbol set directory 314. 

FIG. 8 is a flow chart illustrating the process used to assemble the picture phase information into the 
book file 308. The process begins at 400. At step 401 the header and user data is initialized (310). At step 
402 it is determined if there are any pictures, and if not processing continues at 408 and the book file 308 
is output at step 408. and then the procedure is exited. If. however, there are pictures, the picture data is 

extracted and inserted at step 403. 

Next, at step 404, a determination is made as to whether or not there are symbol sets, if not processing 
continues at step 407 where the picture index 311 is inserted. If there are symbol sets, processing 
continues at step 405 where the symbol set data is extracted and inserted at 313, then the symbol set 
index 31 4 is inserted at step 406. Next Picture index 31 1 is inserted at step 407. 

The graphics are included from ADMGDF files, the device-independent graphics format used by IBM's 
Graphical Data Display Manager (GDDM) product Any symbol sets (GDDM ADMSYMBL files) required to 

display the graphics are included as well. 

The images are included from ADMIMG files, the device-independent image format used by IBM's 
GDDM product It will be understood by those of skill in the ait that any standard graphics and image 

formats could be used instead. 

The picture phase stores the security and copyright notices for the book in plain (uncompressed) text in 

the book file 80. so that it is readable if the file is browsed. 

The names of the pictures are captured ftwn the name used in the DCF .SI control word statement 
through the use of a macro defined in Markup definitions 30. The names are passed to the picture phase in 
a disk file. The picture phase reads this disk file whose first record contains the number of pictures in the 
book. A file couW contain, for example, three pictures. BICYCLE, COMISKEY, and 1000001. where 
COMISKEY is an image and BICYCLE and 1000001 are graphics. 

If there are no pictures, a one is stored in the first two bytes of the book file (the number of 4K picture 
btocks), a zero is stored as the number of pictures, and the file is padded to 4098 bytes. 

If there are pictures, me picture phase stores the number of pictures, and reads the disk file that 
contains names of all the ADMGDF and ADMIMG files that are referenced in the book. A request is then 
made to GDDM to restore each named picture to the normal GDDM display space. The GDDM calls differ 
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for image and graphics pictures. Using GDDM calls, the picture is retrieved from GDDM display space and 
placed into the book file output buffer. 

A particularly tricky aspect of the implementation is the buffer handling shown in RG. 9. The output 
buffer is written to disk whenever less than 4096 bytes remain from the buffer size. Buffer size can be 

5 determined at runtime and depends on available storage. The name, length, and pointer location of the 
picture data is stored in a directory. Any symbol sets (ADMSYWBL files) that were loaded by GDDM while 
the pictures were restored are also indexed in a symbol set directory and the symbol sets themselves are 
stored in the book file. Three conditions are shown for the buffer. The first 500. having four 4096 byte 
blocks 501-504. As more information is added to the buffer at 510. there reaches a point when less than 

10 4096 bytes remain in block 504. At this point the data shown as 505 is moved into the top of the buffer as 
shown by 520. and the data in blocks 501 , 502 and 503 is transferred to disk. 

After all pictures and symbol sets have been stored, the file is padded to the nearest 4K boundary, and 
the number of 4K picture blocks is stored in the first two bytes of the book file. 

FIG. 10 shows the structure of book file 308 when the picture phase ends. Blocks 600 and 620 contain 

IS header data 310 in uncompressed form, and block 610 contains user data 310 also in uncompressed form. 
Block 630 contains the picture directory data 311 including picture name, whether it is an image or 
graphics, its length and a pointer. The pointer points to picture data 640 corresponding 312 in RG. 7. The 
symbol set directory 660 coaesponds to symbol set directory 314 and includes the symbol set name, the 
symbol set type, the symbol set identifier, the symbol set length and the symbol set pointer. The symbol 

20 set pointer points to the symbol set data 650 corresponding to 313 in FIG. 7. Rnally. block 670 is used to 
pad out the file to a 4096 byte boundary, if needed. 

For more information on the formats of ADMGDF, ADMSYMBL. and ADMIMG files, refer to the IBM 
publication Graphical Data Display Manager; Base Programming Reference (SC33-0332). 

The book data stream 60 has a variable record format with a maximum logical record length of 255. 

25 The record type of each book data stream 60 record is in column one. The various record types are 
shown in TABLE 3. 

TABLE 3 



30 



35 



40 



45 



Type of 
Record 

Text 



Search 



Control 



Language 



Columns 



1 



2-255 
1 



3-255 
1 



2-255 
1 



2-255 



Field 



Record Type 



Text 
Record Type 



Search Type 



Text 
Record Type 



Control Data 
Record Type 



Language Name 



Sample Data 



'40'x 



A sentence, 
S 



H 



1.2.1 
C 



SK5 
L 



ENGUSH 



There are four types of records in the book data stream 60: 

1 . Text records contain the plain text of the book. They are used to display the text by the book 

display program 90. 

Text records have a blank in their record type field (column one). Phrases can span multiple text records, 
but words do not span records fi.e., no words are hyphenated). 

2. Search records contain text that is not part of the plain text of the book (e.g., headings, index 
entries, etc.). They are used to create search indexed text by the Indexer/Compressor 70. 

Search records have an "S" in their record type field (column one). Neither phrases nor words span 
multiple search records. Search records are described in more detail below. 

3. Control records contain data that is used to format and display the book. 

Control records have a "C" in their record type field (column one). Control records are described in more 
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70 



? ' Unguage records contain the dictionary name that is used by the Indexer/Compressor 70 to 

compress and index the book. ^ t 

There is oniy one language record in each book data stream 60. and it is the first record In the file. 
Language records have an in their record type field (column one). The preferred embodiment of the 
invention supports only ENGLISH as a language name, but It can be extended to support any language 
supported by the Indexer/Compressor 70. 

A sample book data stream 60 is shown in Example 2. „o« - * ^ \ 

All search records have a search record type in column two. (There is always an S m column one.) 

The various search record types are shown in TABLE 4. 

TABLE 4 



75 



20 



25 



Type of I Columns 
Record 



Search 
Heading 
Text 
Search 
Heading 
Identifier 
Search 
Index 



Raid 



Sample Data 



3-255 



1 1 


1 Record Type 


s 1 


2 


1 Search Type 


T ] 


3-255 


I Text 


1 Overview | 


I ^ 


1 Record Type 


[s 1 


2 


I Search Type 


1 ^ \ 


3-255 


1 Text 


1.2-1 ^ 


1 1 


Record Type 


ri 1 




Search Type 


1 1 



Text 



animals.cats 
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SO 



55 



There are three types of search records: -rn *^ 

1. Search heading text records contain data that is indexed by the Indexer/Compressor 70 as topic 

Search heading text records have a in their search record type field (column two). 

2. Search heading identifier records contain data that is indexed by the Indexer/Compressor 70 as 

topw; identifiers. 

Search heading identifier records have an "H" in their search record type field (column two)^ 

3 Search index records contain data that is indexed by the Indexer/Compressor 70 as index entry 
text (text that appears in the Index of a printed book). Search index records have an I m their search 

record type field (column two). 

Words and phrases never span search records. 

There are several types of control records including header, topic, formatting, menu, contents, and 
index control records described in greater detail hereinbelow. _ ^ ^ * , 

1 header control records precede the first topic in the online book. The header control records ^ 
generated directly by the Markup definitions 30 profile in a separate output file. The Post processor 50 
places this separate file at the beginning of the bocrfi data stream 60. 

Header contrTrecords always have a -C in column one and are found in the header of the online booV 
file. The format of all header control records is: 

Ccontroltype = [controldatal t.^ m 

Unless otherwise specified, each of these records can occur just once within the book header. 

Here are some examples of header control records: 

JISTif^SS'taken from an .AUTHOR tag. If there is no -.AUTHOR tag. then no data follov^s th. 
equal sign. If there are multiple :AUTHOR tags, then multiple AUTHOR control records are present 
This informafion is displayed in the card catalog function, descnbed bekw. 

Sri^vLlTSe'S. taken from the COPYR attribute of the :600C or :USERDOC tag. If there is n 
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COPYR attribute, then no data follows the equal sign. This information is displayed on the title line of all 

panels of the book. 
DATE = [bookdate] 

The date of the book, taken from the :DATE tag. If there is no :DATE tag. then no data follows the equal 
sign. This information is displayed in the card catalog function, described below. 
DOCNUM = [documentnumber] 

The document number of the book, taken from the iDOCNUM tag. H there is no :DOCNUM tag, then no 
data follows the equal sign. This information is displayed in the card catalog function, described below. 
FONTDEF = character type 

A definition for a font within the book. There are multiple FONTDEFs in each online book, correspondrng to 
the fonts defined with overstrike characters in the Markup definitions 30 profile. For a list of each valid 
character and type, see TABLE 1 . 

This information is used to determine how to display highlighted text denoted by the FONT topic control 
record. Each FONT control record uses a font defined by a FONTDEF control record and is described 

below in greater detail. 
LDRDOTS = DOT | NODOT 

The setting of leader dots for the table of contents. It is extracted from the LDRDOTS attnbute of the 
:DOCPROF tag. if present. 

DOT causes periods to separate the heading from its topic identifier when the table of contents is 
displayed. NODOT causes the heading and topic identifier to be placed next to each other. 
SECURITY = [securityclass] 

The security classification of the book, taken from the SEC attribute of the :GDOC or :USERDOC tag. If 
there is no SEC attribute, then no data follows the equal sign. This information is displayed on the title line 
of all panels of the book, unless there is a copyright (from the COPYRIGHT control record). 
TITLE = [booktitle] 

The full title of the book, taken from the -.TITLE or :TLINE tags. If there are no rTITLE or iTLINE tags, then 
no data follows the equal sign. This infomnation is displayed in the card catalog function, described under 
below. 

TOPICS = number 

The number of topics in this book. This information is used with the cun-ent topic's TOPIC# topic control 
record to display the results of the POSITION command, which lets readers see their current location in the 
book. The POSITION command is described further betow. 
VERSION = version 

The release of the implementation that was used to create this book file 80. This information can be used to 
retain compatibility across releases for changes in book architecture. 

2, topic control records occur within topics in the online book, between the SH and ST records in the 
topic. Topic control records always have a in column one and are found in topics of the online book 
file. The format of all topic control records is: 

Ccontroltype [controldata] u eu ^ ct 

Unless othenvise specified, each of these records can occur only once in a topic, between the SH ana b i 

records. 

There are numerous types of topic control records. The following are the more important exampies. 
BACKLEVEL Itopicidl ^. . _ 

The topic identifier of the previous topic that is at the same level in the topic hierarchy as this topic. For 
example, if a book has a :H1 tag followed by three :H2 tags, followed by another :H1 tag, the topic created 
by the second :H1 tag contains a BACKLEVEL control record that fists the topic identifier of tiie topic 
created by the first :H1 tag. If there is no previous topte in the book at the same level, then no topic 

identifier is present . . ^. . •» 

This information is used by the BACK LEVEL command when the online book is displayed and will be 

described below in the description of "Turning Pages in a Book." 

FORWARDLEVEL (topicid] ^ .... ^ . c 

The topic identifier of the next topic that is at the same level in the topic hierarchy as this topic. For 
example, if a book has a :Hl tag followed by three :H2 tags, foltowed by another :H1 tag, the topic created 
by the first :H1 tag contains a FORWARDLEVEL control record that lists the topic identifier of the topic 
CTeated by the second :H1 tag. If there is no subsequent topic in the book at the same level, then no topic 

identifier is present. ^ , ^ . . . 

This information is used by the NEXT LEVEL command wtien the onfine book is displayed as is described 

betow under the description of "Turning Pages in a Book." 
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PARENT [topicid] ^. . c= i » 

The topic identifier of the topic that is one level higher in the topic hierarchy than this topic. For example, it 
a book has a :H1 tag followed by three :H2 tags, the topics created by the :H2 tags each contains PARENT 
records referring to the :HVs topic identifier. If there is no higher level topic in the book, then no topic 

5 identifier is present /^riMTcvr 
This information is used by the SECTION command described below and the QUERY CONTEXT 

command, also descriljed t)elow, when the online book is displayed. 
SUMMARY summarydata 

A summary of the formatting characteristics of the fines in the topic. The SUMMARY record contains a list 
TO of the control records found in the topic that affect spacing (like .SK and .SP) and a list of the text records 
found. 

The formatting control records are listed just as they appear later in the topic, while text records are 
identified by a T" followed by the number of consecutive text records that occur. Each control record or 
text record count is separated by a pound sign (#). There can be multiple SUMMARY records in a topic, but 

15 they must occur consecutively. 

When ttie online book is displayed, this infonnation is used to determine the number of lines ttiat appear in 
this topic for the active display device, and allows readers to go to a topic starting at a specific point (the 
top of the third screen, for example). 
T0PIC# number 

20 The number of this topic within the book. For example, T0PIC# "r Is the first topic in the book. This 
information is used with the TOPICS header control record to display the results of the POSITION 
command, which lets readers see their current tocation in the book. 

3. FORMATTING control records occur witiiin topics in the online book, freely interspersed with text 
and search records. Formatting control records always have a "C" in column one and are found in topics of 

25 the online book file. The format of ail formatting control records is: 

Ccontroltype Icontroldala] h ♦ 

Each of these records can occur numerous times in a topic and each refers to the first text record that 

follows. 

There are numerous types of formatting control records: 

.CP [parametersh Conditional Page control word. Wf^n the online book is displayed. .CP is formatted just 
as DCF wouW format it. See Document Composition Facility SCRIPT/VS Unguage Reference (SH35-0070) 
for an explanation of all possible parameters. 

.PA-Page Eject control word. When the online book is displayed, fomiats PA just as DCF would fomiat it. 
.SK parameters- Skip control word. When Uie online book is displayed, formats -SK just as OOf would 
35 format it See Document Composition Facility SCRIPTAAS Language Reference {SH35-0070) for an 
explanation of all possible parameters. 

SP parameters-Space control word. When the online book is displayed, formats .SP just as DCF would 
format it. See Document Composition Facility SCRIPT/VS Language Reference (SH35-0070) for an 
explanation of all possible parameters. 

FONT startcolumn length font-Change the font of the specified text The starting column and length of the 
text to be displayed are foltowed by a character previously defined by a FONTDEF header control record. 
Except for the FONT record (which is constructed from backspace and overstrike characters), all of ttie 
formatting control records are created from control sequences. 

4. Menu control records occur at ttie end of topics in the online book, listing topics that occur at ttie 
45 next level of ttie topic hierarchy. Menu control records always have a "C" in column one and are found at 
the end of topics of the online bock file. 

Menu control records list upcoming topics at ttie next lowest level of ttte topic hierarchy. For example, if an 
:H2 tag is followed by ttvee :H3 tags, ttie topic created by the :H2 tag will contain menu control records 
listing tfie topics created by ttie ttiree :H3 t^. When ttie onfine book is displayed, these records are used 
50 to show a selectable topic Kst that allows readers to skip to ttie topk: ttie/re looking for. as described below 
when discussing the usage of topic Hsts. 
The format of all menu control records is: 
Ccontrottype [controldata] 
There are three types of menu control records: 
55 EMENU-The end of a topic list menu. 
MENU-The beginning of a topic list menu. 

MITEM topicid topictitie-An item in a topic list menu. A MITEM control record lists an upcoming topic at ttie 
rtftxt level of me toDic hierarchy. The record contains the topfc's topic identifier and the titie provkJed on Rs 
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heading tag. u i, ♦« ♦ 

5. Contents control records occur within the Table of Contents topic in the onhne book. Contents 
control records are created directly by the .TC macro in the Markup definitions 30. These are used by the 
author to indicate an item he wishes listed in the Table of Contents. The Post Processor 50 merely copies 
them into the book data stream 60. 

Contents control records always have a "C" in column one and are found in the Table of Contents topic of 
the online book file. 

\/Vhen the online book is displayed, contents control records are used to display the book's table of 
contents, and their use is desaibed in greater dotal when the use of the Table of Contents Is described 
below. 

The format of all contents control records is: 

Ccontroltype [controldata] 

There are two types of contents control records: 

TOCDEF level space indent font-A contents level definition. The level of heading (0-6) is foltowed by the 
number of blank lines to precede the heading on the contents screen, the number of spaces to indent the 
heading, and the font used to display the heading. (The font must have been defined with a FONTDEF 
header control record.) TOCE level topicid topictitle-A table of contents entry. The record contains the 
topic's heading level, topic identifier, and the tiUe provided on its heading tag. (The heading level must have 
been defined on a previous TOCDEF control record.) 

6. Index control records occur within the Index topic in the online book. Index control records are 
created directly by the .IE and .IX macros in the Markup definitions 30. The author will place these tags in 
the text at entries he wishes to appear in the index. The Post Processor 50 merely copies them into the 
book data stream 60. 

Index control records always have a "C" in column one and are found in the Index topic of the online book 
file. 

When tfie online book is displayed, Index control records are used to display the book's index in two 
columns. 

There are three types of index control records: 

GPSEP/group A group separator-The slash (/) in the above format stands for the delimiter character defined 
by a preceding IDELM control record. The GPSEP record is usually a single character that identifies the 
starting letter of suk)sequent index entries. 

IDEUW character-A character that delimits the parts of ITERM control records. There is only one IDELM 
record and it precedes all ITERM records. 

ITERM/index term words/leveWopicid-An index entry. The slash (/) in the above format stands for the 
delimiter character defined by a preceding IDELM control record. The ITERM record contains the one or 
more words in the index term, the level of the index entry (1-3). and the topic identifier that contains the 

entry. 

The Indexer/Compressor 70 is used to create a search Index for the book file 80 and to compress the 
book's t6xt 

The search index is created using a linguistic dictionary that recognizes word morphologies. The root 
form (or lemma) of a word is related to all of its morphological variants. For example, the word party can 
match parties. Mouse can match mice. Is can match were. Additionally, synonyms of words can be 
matched. 

The Indexer/Compressor 70 is described in copending application serial number XXXXXX assigned to 

the assignee of the present invention. 

As shown in FIG. 1 1 , an online book file contains the following elements: 

1. FILE POINTER 700 which is the offset of the location of the compressed text. 
U.SECURrrV/COPYRIGHT 701 which is the security classifk:ation and copyright notice of the book, taken 
from the SEC and COPYR attributes of the :GDOC or :USERDOC tags, if present. 

2. PICTURES 1002. which are the GDDM ADMGDF (graphics) or 6DDM ADMIMG (image) formats 

containing the pictures in the book. 

3. COMPRESSED TEXT 703. which is the text in the book, in a compressed form to save disk space. 
It will be clear to those of skill in the art however, that the compressor is not necessary if disk usage is not 

limited. . . ma 

4. SEARCH INDEX 704, vtrhich includes the occurrence and location data about the words ana 

ohrases in the book. 
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READING AN ONUNE BOOK 

Once an online book is created, and the book data stream created as detailed hereinabove, the 
Invention allows you to read, navigate, and search the book. The components of the reading phase are now 
described. 

The reading phase of the invention manipulates the uncompressed form of the book data stream 60. In 
the preferred embodiment books are always compressed, to save disk space, so all reading from the book 
file includes decompression. While not described herein, it will be apparent that if the book data stream has 
been compressed, it will need to be uncompressed before proceeding with the method described herein. 

Many hardware characteristics of the display device are used dynamically to present the book. These 
characteristics include the screen size, color capabilities and highlighting capabilities of the display. 

The SUMMARY control record of the book data stream 60, discussed above, allows the took to be 
dynamically formatted on a screen of any length. 

The FONTDEF control record, and the FONT control record, also described above, allow cotor and 
highlighting capabilities to be dynamically selected on any display device. For example a FONT record 
produced from a second-level highlighted phrase (:HP2) might be a different color (from normal text) on a 
color display device. On a monochrome device, it might be underscored. All the FONTDEF control records 
in a book are read before any topic is displayed. 

The book display program 90 converts the book data stream 60 into a book display output stream 120 
that presents the book display on the screen 130. The book appears as shown in FIG. 12. 

The general approach for displaying one screen of information from a book file on the screen is as 

follows: 

1 . Look for the topic. If a new topic Is to be displayed. 

a. Position the book file to the topic and read the topic-related header records. 

See the online fc>ook file architecture for a description of the content and format of these records. 
A topic begins with a search record (SH) containing the topic identifier, and a control record (GTOPIC#) 
giving the internal sequence number of the topic. Other topic-related header records contain, for example, 
the topic title, the previous/next topic, the name of the source file for the topic. 

b. Set the starting and ending book file record locations for each of the topic's panels. 

This is cateulated from the topic summary record (CSUMMARY), using information about the screen size 
and the sizes of non-text elements currently on the screen (eg., position of the command line, number of 
lines required for the title and copyright/security infonnation. lines devoted to the PF key display). This is 
done dynamically to take into account the formatting rules for line skipping, line spacing, and page ejects. 

c. Format the subtopic list (subtopic menu), if present 

There is a subtopic list if the topic ends with a CMENU/CEMENU control statement sequence. The records 
between these are CMITEM control records, which will be formatted with special screen attributes that altow 
selection. 

2. If the topic is being displayed as a result of a search command, calculate the panel with the match. 
The search engine provides function used to identify the location of the matching tine. 

3. If the topic is to be returned in ttie CMS queue, queue it and leave. 

The RTRN YES option is an internal option used to request that tiie topic be put in the CMS queue. It is 
used, for example, to obtain an extended message description from ttie messages manual, or to obtain a 
command sunrunary from tf^e command summary reference manual. This function allows the invention to 
recursively invoke itself to provide help for its users. The text thus extracted from the help manuals is 

presented in an onscreen window. 

4. If the topic has a note, set up to display the indicator on tiie status line. 

Notes are kept in a separate file. They are associated with specific books by a simple naming convention. 
In the target operating system of tfie first implementation files have two-part names called, respectively, file 
name (tn*) and file type Cft*)- Each component of the two-part name may be up to 8 characters tong. Online 
books are distinguished by a 'ft' of book. The files containing online notes for online books are named with 
an fn* that is the same as that of the book, and an ft' that corresponds to ti^ userid of the person taking 
the notes. Thus files are easily distinguishable as to what dass of file they are (online txx)k or notes), and 
the files of onfine notes may be easily associated with their owners. The online notes themseNes are stored 
by topic identifier, and line within the topic to which timy apply. (The granularity of this method could easily 
be to the indwldiral word within ttie line. The word-within-Bne information is captured and stored but not 
acted upon in the current implementation.) 

5. If the note window is to display, set op to display it 
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Whether a note window is to display depends on these factors: 

a. The user of the book may command the book reading program explicitly to display notes if 
there are any. (This is called the NOTES SHOW function.) 

b. The user of the book may be reviewing notes. (This is called the REVIEW NOTES function.) 

6. If the book position is to display, set up to display it on the status line. The topic sequence number 
(CTOPIC#) is used to calculate the POSITION. 

7. Display the topic. 

This entails composing the screen and passing the description and contents of the screen to GDDM (the 
system-provided display device manager used in the preferred embodiment). In the preferred embodiment, 
this is done by programs which are written separately. This is done so as to maintain the device- 
independence of the invention. The programs that interface directly to the device drivers of an operating 
system need to reduce to specific device characteristics the information that has so far been carried in 
abstract form. How the display device interface program works is described further betow. 
Each of the non-text and textual elements of the screen is composed separately. For the purpose of this 
discussion, the non-text elements are: the action bar at the top of the screen, the tailorable function key 
display at the bottom of the screen (which may be entirely suppressed by the user or may show the 
meanings of up to 24 function keys), the command line (which may be at the top or bottom, at the user's 
preference), the message line (which is kept above the command line), the status fine (which contains, for 
example, the indicator that a topic has notes associated with it), and any onscreen windows that must be 
shown. 

The textual elements are composed of the records read from the topic. These include the topic identifier 
and title (SH and ST records, respectively), text records (blank in column 1), format controls (C records for 
spacing, skipping and page ejects), and font/highlighting controls (CFONT records). Some book-tevel 
information is also used in the composition of the topic display: specifically, we have previously read all the 
FONTDEF records, to know how to interpret the CFONT records. In the preferred embodiment the security 
and copyright information is stored at the book level, but could be set individually for each topic, H the 
markup language permitted it Copyright or security information is displayed at the top of each screen atong 
with the topic title. 

The description of the composed screen is set into an array of program variables, and the display interface 
program is invoked. An example of the array is shown in Example 3. 

8. Upon return from displaying the screen, reset variables and check for an action bar related choice. 
The program resets variables associated with the panel just displayed, for example, whether the terminal 
alarm should sound. 

The book display program then determines if the user chose something related to the action bar. for 
example, an action bar choice, a pull down window choice. 

a. If an action bar choice, create the pull down window. 

b. H a pull down window choice for a pop up window, create the pop up window. 

c. If a pull down window or pop up window choice for a command, set the command. 

d. If a window-related function key choice, set the corresponding command. 

9. If a pull down window or a pop up window was created, redisplay the topic. 

10. If a notes window was displayed see if the note should be saved. 

The subroutine Notesave checks if the note was changed. If it was, it uses the subroutine Notewrite to save 

the new notes file. 

11. Remember the action taken by the user to allow RETRIEVE, REVIEW, and tracing. 

12. If the user selected a topic from the QUERY SAVE window, remove it from the list 

The inventkm's display device interface includes three major functions, namely: 1 )initialize the display 
device driver program (GDDM in this implementation). 2) display a screen using GDDM. and 3) display 

fiDDM These maior furtcUons are described below. 



1 . INITIALIZE THE DISPLAY DEVICE DRIVEN 

This function is performed once only during the book display program. Its purpose is to extract from 
operating system's display device manager pertinent information about the end user's display device, 
device characteristics are preserved for use by the other functions. TABLE 5 lists the infomnation stored. 
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TABLE 5 



Field 


Length 


Description 


1 Rag 77 




3277 flag: 0 or 1 


1 CharAtt 


- 


Character attributes: 0 or 1 


1 oy5I6iM 




1 Svstem* CMS or ESO 


1 APLflag 


1 


FaPL Rag: 0 or 1 


RowsNr 


3 


Rows on screen 


ColsNr 


3 


1 Columns on screen 


1 BoxH 


2 


Height of character box 


BoxW 


2 


1 Width of character box 


1 ColorNr 


2 


1 Number of colors 


1 High 


1 


1 Hilight feature: 0 or 1 


PSSNr 


2 


1 Number of program symbol stores 



2. DISPLAY A SCREEN USING GDDM: 

This function has available the information about device characteristics described in TABLE 5. It 
receives the description of the composed screen that has been previously set into an array of program 
variables for its use. An example of data in the array Is shown in Example 3. 
There are three types of records in the array: 

a. Control records are used to provide information to this function. They have an asterisk 0 in column 
one. Following the asterisk is a keyword that describes the information: 

1) OPTIONS Defines global settings for the display interface program, such as whether the current 
data on the screen should be cleared, or whether it should wait for input after displaying the screen. The 
OPTIONS record must be the first record in the array. 

2 ATTRNR Defines the number of ATTR records to follow. The ATTRNR record must precede all 

ATTR records. ^ ^ . . ^ 

3) ATTR Defines an attribute character. Attribute characters that follow escape characters m data 
records signify a change In display characteristics. Attribute characters that do not follow escape characters 
are treated as text. Attribute characters can change field type (protected, unprotected, light pen), color, or 

highlighting. ^ ^ ^ ^ 

4) ESC Defines the escape character. When this character appears in a data record, the next 

character is examined to see if it matches an attribute character. 

5) EATTR Defines the end attribute character. When ttiis character follows the escape character in 
a data record, it ends the field started by the preceding attribute character. The default display characteris- 
tics {set by the Entity record) are restored. 

b ENTITY Defines a separate part of the screen. They have a plus sign ( + ) in column one. The 
name foltowing the plus sign is the name of the entity. The information provided on an entity record 
includes all of the information on an attribute record, which defines the default display characteristics for 
that entity. Attribute characters (with escape characters) in the data can ovenide these defaults. 
Entity records also include the location of ttie entity on the screen, and wheUier the data is in field or 
character attribute fonnat If this entity overtays other entities, a GDDM partition is created to display the 

Entity records are sometimes foltowed by records tiiat define cumx location ( + CURSOR) and the color of 

borders ( + TOPBORDER) around the entity. 

c. DATA Provides data to be placed within the current entity. They have a blank in column one. Data 
records are displayed using the characteristics defined by their entity, except that data fotowing escape 
characters arxJ attributes are displayed as the attributes are defined. 
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The device characteristics teH whether the device supports character or fieki attributes. The last entity 
record tells whether the data was formatted as character attribute data or field attribute data. Depending on 
the combination of these conditions, one of the following actions is taken: 
a. The character data is aligned for a ctiaracter device, 
s b. The field data is aligned for a character device. 

c. The Field routine is called to display each field in the data record. 
The screen is displayed, a response from the user is awaited, if needed. The response is returned to 
the book display program through settings of program variables. The following information is returned: 
. the name of the entity that contains the cursor 
10 . the cursor location 

. the values of all input areas 

. the cause of the interrupt (key press, light pen, etc.) 

. any light pen area that was selected 



75 
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3. DISPUY GRAPHICS OR IMAGE USING GDDM: 



This function is called by the book display program's PICTURE command to display a GDDM picture. It 
has available the device characteristics information described in TABLE 5. It uses the data structure created 
20 by the Post Processor 50 Picture Phase (shown in FIG, 10) to quickly load and display the picture. A 
Hierarchical Input Output diagram for the display picture process is shown in FIG. 13. A flowchart of the 
display-pictures flow is provided in FIG. 14. Pictures are requested by name. 

Refer now to FIG. 13. The book file 700. corresponding to the structure shown in FIG. 10. is processed 

at 710 to provide a display 720. 

25 Referring to FIG. 1 4. the process for displaying pictures begins at 800. At step 801 the picture entry is 
located. If its name is not found.the routine exits at 809. Othenwise process continues and determines if the 
picture is graphic at step 803. if so. process comments at 804 are obtained and the picture data obtained at 
step 805. If not processing jumps to step 805 where the picture data is obtained. At step 806 the picture 
data obtained is examined to determine if it is an image. If it is not the picture is displayed at step 808. If it 

30 is. it is scaled to fit the screen at step 807 and then displayed at step 808. After the picture is displayed the 

routine is exited from via step 809. 

a. First the number of pictures in the file is checked-if it's zero, return immediately. 

b. If there are pictures in the file, use the picture name directory to find the picture. If the picture 
exists, use the image/graphic indicator to choose which GDDM calls shoukJ be used to load the picture. 

35 Using GDDM commands, the picture data is restored from the book file to the GDDM area, from which it 
can then be displayed. 

c. If it's a graphic, (that is. it originated from an ADMGDF file), the GDF comment orders which 
preceded the visual data are read and used to set up the environment for the picture before it is loaded. For 
example, if a picture requires a symbol set to be loaded, use the symbol set directory to find and toad the 

40 needed symbol set. 

d. For ADMIMG format pictures (scanned images), the image has to be scaled to fit the display 

screen, and it is centered on the screen. 

e. Finally, process the response to the picture. If the response ts to enter GDDM User Control Mode, 
call user control to altow zooming and panning the graphic. User Control Mode is not allowed for image 

45 pictures. 

Now the novel elements of the invention that imitate a hard copy book are described. 
Just as hard copy books are read by turning pages, an online book is read by turning its pages, or 
panels. Pressing the "Fwd" function key. F8. turns fonward in a book. Pressing the "Skwd" function key. F7. 
turns backward in a book. 

The "BACKWARD" and "FORWARD" commands also can be used to turn several panels at once. For 
example. 

Command = = => fonrfard 3 
turns ahead three panels. 

The "LEVEL" operand of the "BACKWARD" and "FORWARD" commands can be used to skip to the 
55 topic at the same level in the hierarchy as the one on the screen. For example, if topic 2.0 is being 
displayed. 

Command = = - > forward level 

turns ahead to topic 3.0. even if there are other tower-level topics (2.1 . 2.2. etc.) in between. 
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The invention includes all of the familiar parts of hard copy books online for easy navigation through the 
information. The "book parts" action allows selection of the table of contents, figure list, table list, and 
index. The book parts action window is shown in FIQ. 15. 

To see a book's table of contents, select "Contents" from the "book parts" acUon window, or enter 

5 "CONTENTS" in the command area. 

When "Contents", is selected, the book's table of contents is displayed. 11 looks very similar to a hard 
copy table of contents, except the titles are followed by topic identifiers instead of page numbers. To see a 
topic, select rts topic identifier. Each entry has the topic heading followed by the topic identifier of the topic. 
Rom the table of contents, a topic can be selected to be shown. 
70 The table of contents is formatted from the TOCDEF and TOCE control records described betow. 

To see a book's figure list, select "Figures" from the "book parts" action window, or enter "FIGURES" 
in the commartd area. 

When "Rgure list" is selected, the book's figure list is displayed. It looks very similar to a hard copy 
figure fist, except the titles are followed by topic identifiers instead of page numbers. To see a topic, select 
75 its topic identifier. A figure list may look like this: Each entry has a figure number, followed by tiie figure 
caption, foltowed by the topic identifier of the topic that has the figure. From the figure list, a topic can be 
sGl6ct@cl to bd shown. 

To see a book's table list, select "Table list" from the "book parts" action window, or enter "TABIDS" 
in the command area. 

20 When "Table list" is selected, the book's table nst is displayed. It looks very similar to a hard copy 
table list, except the titles are followed by topic identifiers instead of page numbers. To see a topic, select 
its topic identifier. Each entry has a table number, followed by the table caption, followed by the topic 
identifier of the topic that has the table. From the table list, a topic can be selected to be shown. 

To see a book's index, select "Index" from the "book parts" action window, or enter "INDEX" in the 

25 command area When "Index" is selected, the book's index is displayed. It looks very similar to a hard 
copy index, except the index terms have topic identifiers instead of page numbers. To see a topic, select its 
topic identifier. From the index, a topic can be selected to be shown. Also, a letter can be entered in the 
command area to see the panel with the index terms beginning with that letter. 

The index is formatted from the GPSEP. IDELM. and fTERM control records described below. 

30 While reading a hard copy book, a reader often needs to save his place. He may want to temporarily 
save his place while reading, for example, by keeping his finger on the page. He may also want to save his 
place when he closes a book, for example, by inserting a bookmaric. The invention lets him do these things 

while reading an online book. 

A reader may. while looking for information in a book, want to go back to places that he's already seen. 

35 He can marie certain topics temporarily so they can be found later. 

The SAVE command makes it easy to save a place in a book. This command can be used in any topic 

of the book to be saved: 
Command = = => save 

The reader can then wander away from the saved topic and return to it whenever he wants. He can save 
40 several places and go back to tiwm in the order in which he saved them. Topics stay merited until the 
reader closes the l)ook or returns to the saved place. 

The RECALL command is used to return to the most recently saved place: 

Command = = => recall 

The invention also provides a "REVIEW" command, that lets readers back-track through all topics 

<5 previously seen, without having to SAVE them. 

The QUERY SAVE command is used to see a list of the places that have been saved: 

Command = = => query save 

There are times when a reader wants to save a home base within a book. This Is Oke putting a paper 
clip on a certain page. No matter where else the reader goes in ttie book, he can always return to this spot 
whenever he wants. The home base is saved until a new home base is saved or the book is closed. 

The SAVE HOME command is used to save a home base: 
Command = = => save home 

The RECAU. HOME command always returns to the home base: 

Command = = => recall home 
55 These commands make it convenient to examine otiier places from a home base, and return to it later. 
When a reader doses a book, he can put a bookmarit at the place in the book where he stopped, and. 

later, fie can reopen the book to the bookmark. 

''CvH" ic onfl nf thft artions alwavs available to the reader. When "Exit" is selected, a window foi 
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closing the book is shown. "Exit book with bookmark" can be chosen to leave the book, thereby saving the 
place for the next time the book is opened. The bookmark information is stored on disk 140. 

When a reader opens a book that has a bookmark, he is told that there is a bookmark. To go to the 
place that is marked, he uses the "book parts" action window see Rgure 1 4 or the BOOKMARK command: 
5 Command = = => bookmark 

The topic with the bookmark is shown and the bookmark is removed. 

One of the major difficulties in using information is understanding the structure of the information 
without losing context. The invention understands the structure of the online book. There are several ways 
in which this knowledge can be used by the reader to retain the context of the information. 

10 One way the invention helps retain the context information is by displaying lists of upcoming topics to 
allow readers to see. and quickly jump to, lower levels of the topic hierarchy. This is similar to a partial table 
of contents or subject tabs in hard copy books. For example, if a 6ML source file contains a first-level 
heading (:H1), followed by three second-level headings (:H2s). the text for the :H1 would be followed by a 
list of the three :H2 headings, as shown in FIG. 14. The reader can place his cursor on any of the topic 

75 identifiers, such as 3.2. and press ENTER to go directly to that topic. 

This is an easy way to navigate down the hierarchy to more and more specific information, until 

eventually the needed information is found. 

Topic lists are created from the MENU. MITEM. and EMENU control records described previously. 

The SECTION command is used to see the section to which the current topic betongs. This is the topic 
20 above the current topic. For example, if topic 3.11.2 is being displayed, entering "SECTION" shows topic 
3.11. If "SECTION" is entered while viewing topic 3.11. then topic 3.0 shows. The SECTION command is 
an easy way to back-track up the hierarchy (the reverse direction from topic lists). 

The SECTION command uses the PARENT control record, described above, to determine the topic to 

go to. 

25 It is also possible for readers to display the context of a topic in the topic hierarchy. This example 
requests a list of topics that are above the current topic: 
Command = = = => query context 

The QUERY CONTEXT command uses the PARENT control record described above to determine the 
hierarchy. 

30 The position command is used to find out where the reader is-the place in the book 110. This is 
equivalent to looking at the skJe of a hard copy book to see how much has been read, and how much is left 
to read. The depiction of position may be done in several ways. The cun^ent implementation provides two 
ways of doing it. 

"POSITION SCALE" requests that the position be shown on a scale. For example, the response: 

35 bookposition: | '...j 

indicates that the topic being displayed is about three-quarters into the book. SCAl-E is the default. 

The preferred embodiment uses an idealized horizontal depk:tion of the position scale. The scale is 
shown with ten divisions, and the position is rounded to the nearest ten percent. Other methods of depiction 
could use a vertical scale, or different granularity of depiction. 
40 "POSITION PERCENT* requests that the position be ^own as a percentage. For example, the 

response: 

bookpercent: 75% 

indicates that the topic being displayed is abovt 75% into the book. 

The invention also provides several functions to make and view notes for a book. In addition to making 
45 notes on topics for personal use, notes from others can be distributed and reviewed. The notes are stored 
on disk 150. separately from the book itself. 

LOOKING AT THE NOTES IN A BOOK: To view a note, select "Make or change a note" from the 

"Notes" action window, or enter "NOTES" in the command area. The note window is displayed. 

The bottom of the note window shows function keys that make it convenient to use the various notes 
so functions. Function key 3 (End), for example, removes the note window from the screen. 

A note can be larger than the note window. Functfon key 8 scrolls fonward to create or see additional 
lines. Function key 7 scrolls back. 

The invention makes it convenient to review just the topics that have notes. This is particularly useful for 
going through a book tooking at notes from other readers, and is described in further detail below. 
55 To kxjk at only topics that have a note, enter: 
Command = = => review notes 

The review notes functton t>egins with the first note in the book. 

Using this review function changes the meaning of the ENTER key. The next topic rwte or line note is 
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displayed when ENTER is pressed. When the last note has been reviewed, reviewing ends and the ENTER 

key returns to its normal function. 

To make or change a note, select "Make or change a note" from the "Notes" action window, or enter 
"NOTES" in the command area. A note window is displayed, which becomes the note input area. 
5 When a topic has a note, a message appears on the panel. Also, if the topic has line-related notes, 
each line wKh a note has the character > at the beginning of the line. The reader can change the contents 

of a note by typing in the note window. 

A note is created for the entire topic by leaving the cursor in the command area when requesting the 
note function. It is sometimes useful to associate a note with a partk:ular line of text within the topic. To do 
TO this, put the cursor on the line and request the note function. 

1. To create a line note using the NOTES command, type the command "NOTES" in the command 
area, move the cursor to a text line, and press the ENTER key. 

2. To create a line note using the NOTES function key. move the cursor to a text line, and press the 
function key for NOTES. By default, this is function key 5. Notes can be created for any number of topic 

T5 lines. Each line with a note is identified with the character > to the left of the line. 

Another function key. for example function key 4. is used while within the note window to delete an 
entire note. The entire note window is removed and the topic or line no longer has a note- 
Notes from other readers can be accessed with the "NOTES ADD" command with that reader's userid. 
Alternately, the "QUERY NOTES ALL" command can be used to obtain a list of ail readers who have notes 
20 for this book. 

Several readers' notes can be placed into a single notes file by issuing a "NOTES MERGE" command 

with the userids of the readers. 

To send notes to another reader, select "Send notes" from the "Notes" action window, or enter 
"NOTES SEND" in the command area. A special panel allows entry of the userid and node of the reader to 

25 whom the notes shouW be sent. 

One of the more powerful functions of the invention is the way it handles notes and their association 

with a book. A simple procedure can be followed so that 

1 . A writer uses the invention to create an online book, then sends it out for review. Sending out for 
review may mean the physical transmission of the book file over telecommunication links, or making the 

30 book file available to other users on a multi-user computing system that has file sharing capability. 

2. A reviewer looks at the book online and creates comments on the book as described above. 

3. The reviewer's comments are sent to the book originator and shared as previously described. 

4. The book originator reviews the original book online and sees the reviewer's comments on the 
book. Use of notes from others and review of topics with notes has been previously descrilwd. 

35 The invention can also list available onfine books, from which a book can be opened or its catalog card 
(as in a library's card catalog index) can be displayed. 

EXAMPLE 1 

40 

An example of a GMI. source file for a real book about Local Area Networks is shown below. 



45 



50 



55 



26 



EP 0 384 986 A2 



:gdoc sec«'Unc1ass{ fied'. 

; frontm 

:ttt1ep 

:title.Local Area Networks 
:Uocnu[n. 01-00 
: date. November 9, 1987 
:.nuthor. IDfl Corporation 
: address. 

:aHne. Corporate Headquarters 

raline.Armonkt NY 

:eaddress 

:etit1ep 

:toc. 

: f igl ist 

:body 

:hO. Introduction 

:p.This document talks about :hpl, Local Area Netvforksrehpl. 
(LANs). 

:hp2.Read this document to )earn how they wprk:ehp2.. 

:p.You can learn: 

:ol 

:H.^hen you need a tAN 

:H.How to share hardware devices using: 

:ol 

:li.File servers 
Print servers 

:eo) 

:1i.How LANs are connected 
:eol 

:hI.Hhat UNs Oo 

: p. Local Area Networks connect personal computers to one another 
so that PC users can share data and software. 
When two users are connected to a LAN, they :hp3. never: ehp3. 
have to pass floppy disks to each other to share information 
or programs. 

:p.You can also use LANs to share a printer or fixed disk* 
Some LAN systems allow two users* to :hp2,simut taneous)y:ehp2. 
update the same database. 

:p.You can even connect LAtls to :hp3.host:ehp3. computers! 
: hi. How LANs Work 

:p.This section discusses how LANs share hardware devices 
and how they are connected. 
:h2. Sharing Hardware Devices 

: p. LANs can save you money by letting multiple PC users share 
an expensive fixed disk or printer. 

LANs do this using :hpl.servers:ehpl. , which are PCs that 
control the hardware. 

(lost people use :hpl. file' servers:ehpi. and :hpl. print serversrehpl. 
:h3.File Servers 

:p.One connon use for o local area network is to share access to a 
fixed disk that contains files that 
are needed by multiple PC users. 
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EXAMPLE 1 (continued) 

To accomplish this, one PC in the LAN accepts requests from the 
users* PCs to read and write records in the shared files. 
:i I. server 

This PC is called the file server, and its operation is shown in 

:figref refid=*serve'.. 

tfig frame^rule id='serve* place^inl Ine. 

PC 



PC — Server — Fixed OisK 



PC 

rfigcap.A File Server 
:efig 

:note.This diagram depicts a LAN that uses a thpUstar topology: ehpl.* 
See :hdref refid=*top* for information obout topologies. 
:h3. Print Servers 
:il. printing 

: p. Another way to use a local area network is to share access to a 
printer. 

To accomplish this, one PC in the LAN accepts requests from the 
users' PCs to print data on the shared printer. 
:i 1. server 

This PC is called the print server, and its operation is shown below. 
:hp3.A PC can be a print server and a file server simuUaneously:ehp3. 
tfig frame=rule place=inline 

PC 



PC — Server PC 



Printer 

rfigcap.A Print Server 
:efig. 

:note.Thts diagram depicts a LAN that uses a :hpl.star topoiogy:chpi,. 
See :bdref refid«'top*' for information about topologies. 
:h2 id»' top*. Connections 
iM id=»' top*. topology 

:p. Local Area Networks can be connected in two topologies: 

:ul compact 
:iZ refid»' top '.ring 
:il.ring topology 
; 1 i . ri ng 

:i2 refid»' top'. star 
riKstar topology 
;11.5tar 
:eul. 

:p.See :figref refid-'LAHtop' for an illustration of each. 
:fig 1d=»»LANtop' fraroe^'rule' place^inline. 
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EXAMPLE 1 (continued) 



PC 



PC 



PC 



PC 



FC — Server PC 



PC . Server 



PC 



:figcop.Ring and Star Topologies 

:cfi9 
-.index 

regdoc. 



EXAMPLE 2 



An example of records found in the Book data stream (60) for a real book about Local Area Networks is 
shown b6k)w. 

Some of the SUMMARY control records are too long to fit easily on a printed page. Records that end in 
three dots have been truncated for this example. 
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LEKGLISH 

CVERSIOH^l.O 

CSOURCE-PCLAN SCRIPT 

CTITLE^Local Area networks 

CSTITLE=Local Area Networks 

CCOPYRIGHT- 

CSECURlTY=Unclossified 

CRESHATl» 

CRESr4AT2= 

CREStlAT3== 

COATE°Hoverober 9, 1987 
CAUTHOR»lBH Corporation 
CALIHE»Corporate Headquarters 

CALIME«Annonk, NY 

CDOcnuH=oi-oe 

CFRONT=FROHT 
CCOHTENTS=COHTEHTS 
CFIGURES-FIGURES 
CTABLES=TABLE5 
C INDEX" INDEX 
CLDRD0TS=O0T 
CFOHTDEF=e H0 
CFONTOEF=H HI 
CFONTDEF»I H2 
CFONTDEF=J H3 
CFONTOEF»iC H4 

CFOrU0£F-L H5 
CFOHTOEF=M H6 
CFONTDEF* UNDERSCORE 
CFONTDEF«=I HP I 
CF0NT0EF^2 HP2 
CFONTDEF-3 HP3 
CF0MTDEF=4 HP4 
CFOMTDEF-5 HPS 
CF0NT0EF=6 HP6 
CFONTOEF-7 HP7 
CF0NTDEF«8 HPS 
CF0NT0EF»9 HP9 
CFONTDEF^A APL 
CFONTDEF=C CIT 
CFOHTOEFi^ CAUTION 
CFONTOEF-r CAUTIONTEXT 
CFONTDEF^ DANGER 
CFONTOEF-0 OANGERTEXT 
CFONTOEF«U WARNING 
CFONTDEF<^ WARNINGTEXT 
CFONTOEF=P PK 
CFONTDEF=Q PKOEF 
CFONTDEF-V PV 
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EXAMPLE 2 (continued) 

CFOHTOEF=*Z PVOEF 
CFOHTOEF-T TP 

CFONTOEF»R RK 
CFOHTOEF«>X XPH 
CFONTDEF-E XHP 
CFONTOEF-U MO 
CFONTOEF=Y KDQUAL 
CSW40ELIH=I 
CHARGIN»2 
CREVISIONS 
CRC I 5 6 
CEREVISIONS 

CT0PIC5=U 
SHTITLE 
CTOPICI 1 
CPARENT 

CFORHARDLEVEl COHTEHTS 
CBACKLEVEL 

CSlffWARY TITLE .CP#.SP 12#T1I.SIC 12tfTlif.SK 2*T1I.SK 9ffTl*.SK Itf.SP U... 

CHOLEVEL : TITLE 
CSOURCEFH PCLAn 

ST Title Page 
C.CP 
C.SP 12' 
CFONT 58 5 2 
CFOHT 54 4 2 

^ 2 ^^^^^ ^^^^ 

^ Oocuroent number 01-00 

^'^^ ^ Hovember 9» 1987 

^'^^ ^ IBM Corporation 



C.SK 1 
C.SP I 



Corporate Headquarters 

Armonk, NY 



C.SK 3 

CFONT 65 12 2 Unclassified 

C.SK 3 
SHCOKTENTS 
CTOPICI 2 
CPARENT 

CFORtfARDLEVEL FIGURES 

cSfYVHiS^S llL16llL26#lL29feL16nL16llLl7H2L30#3L20f3L2U2L17nLU 

CHOLEVEL :TOC 

CSOURCEFH PCUH 

ST Table of Contents 

CTaCOEF«=e 18 2 

CTOCOEF-l 18 2 

CTOCOEF-2 8 0 

CT0CDEf=3 8 2 

CTOCOEF-^ 8 4 

CT0CDEF°5 8 6 

CT0CDEF«6 8 8 

CTOCE 1 TITLE Title Page 
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EXAMPLE 2 (continued) 

CTOCE 1 CONTENTS Table of Contents 
CTOCE 1 FIGURES List of Illustrations 
CTOCE 0 1.0 Introduction 
CTOCE 1 l.l What LAfts Do 
CTOCE I 1.2 How UNs Work 

CTOCE 2 1.2,1 Sharing Hardware Devices 

CTOCE 3 1.2.1.1 File Servers 

CTOCE 3 1.2.1.2 Print Servers 

CTOCE 2 1.2.2 Connections 

CTOCE 1 INDEX Index 

SHFIGURES 

CT0PIC# 3 

CPAREMT 

CFOR^JAROLEVEL 1.6 
CBACKLEVEU CONTENTS 
CSUmARY FIGURES T3#.SIC 2 
CIIOLEyEL :FIGL1ST 
CSOURCEFK PCLAN 

ST List of Illustrations 
CSELECT 70 7 T 

Figure 1. A File Server .... i ? i i 

CSELECT 70 7 T u^.i.i 

figure 2. A Print Server 171? 

CSELECT 72 5 T i-^-i-c 

Figure 3, Ring and Star Topologies . , 177 
C.SK 2 ^'"^'^ 

SHl.O 

CTOPICff 4 
CPARENT 

CFORHAROLEVEL 
CBACKLEVEL FIGURES 

ru™J '^^ 1*T2*-SK mi#.SK UTU.SK mifl.SK HTU.SK ISUB.SK WTlff.SK 2 
CHDLEVEL :H0 

CSOURCEFN PCUN 
ST Introduction 
C.SK 1 

CFONT 29 5 1 
CFOHT 35 4 I 
CFOHT 40 8 1 
CFOKT 58 4 2 
CFOHT 63 4 2 
CFONT 66 0 2 

CFONt's fl"^^^ ^^^^^ ^^"^^^ ^^^^ Networks (UHs). Read this document 

CFONT 6 5 2 
CFONT 12 3 2 
CFONT 16 4 2 
CFONT 21 4 2 

to learn how they work. 
C.SK 1 

You can learn: 
C.SK 1 

1. tihen you need a LAN 
CSK 1 

2. How to share hardware devices using: 
C.SK 1 

a. File servers 

C.SK 1 
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EXAMPLE 2 (continued) 

b. Print servers 

C.SK 1 

3. How LANs ore connected 
C.SK 2 
CMEKU 

QUTEH 1. 1 Whdt LA^ts Do 
CMITEM 1.2 How LAWs Work 
OMWK mix Index 
Cet^ENU 
SHI. I 
CTOPICff 5 
CPARENT l.G 
CFORHAROIEVEL 1.2 
CBACKLEVEL 

CSWWARY l.l .SK 1(IT4#.SIC IHXZS.SK lffTl#.SK 2 
CHOLEVEL :Hl 
CSOURCEFN PCLAH 
ST What LAtls Do 
C.SK 1 

I Local Area networks connect computers to one another so that PC users can 
share data and software. When two users are connected to a LAN, they 
CFONT 3 5 3 

never have to pass floppy disks to each other to share information or 
programs. 
C.SK I 

You can also use LAHs to share a printer or fixed disk. Some LAN systems 
CFOHT 22 14 2 

allou tvfo users to simultaneously update the same database. 
C.SK I 

CFOHf 32 4 3 

You can even connect LANs to host computers E 

C.SK 2 
SHl.2 
CTOPICI 6 
CPARENT l.O 
CFORUARDLEVEL INDEX 

CBACKLEVEL l.l 

CSUHHARY 1.2 .SK 1#T2II.SK 2 

CHDLEVEL :Hl 

CSOURCEFN PCLAN 

ST HoH LANs Work 

C.SK I 

This section discusses hov UNs share hardware devices and how they arc 

connected. 
C.SK 2 
Ct4ENU 

CHITEH 1.2.1 Sharing Hardware Devices 

CHITEM 1.2.2 Connections 

CEHENU 

SHI. 2. I 

CTOPlCi 7 

CPARENT 1.2 

CFORWAHOLEVEL 1.2.2 

CDACKLEVa 

CSUIU4ARY 1.2.1 .SK UT3*.SK 2 

CHDLEVa :H2 

CSOURCEFN PCLAH 

sr Sharing Hardware Devices 

C.SK 1 
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EXAMPLE 2 (continued) 

LANs can save you money by letting nujltiple PC users share an expensive 
CfOHT 46 7 1 

fixed disk or printer. LAHs do this usina servers, which are PCs that 
CFONT 42 4 I 
CFONT 47 7 1 
CFONT 59 5 I 

CFOMT 65 7 1 

control the hardware. Host people use file servers and print servers. 
C.5K 2 

CrUTEH 1.2.1.1 File Servers 

CKITEf^ 1.2.1,2 Print Servers 

CEHEMU 

SHl.2.1.1 

CTOPlCff 8 

CPAREHT 1.2-1 

CFORHAROLEVEL 1.2.1.2 
CBACKLEVEl 

CSW-WARY 1.2.1.1 .SK l.flTStf.SP IffTlOtf.SP lffT2#.SK WZS,%K 2 
CHOLEVEL :H3 
CSOURCEFM PCLAH 

ST File Servers 
C.SK i 

I A common use for a local area net^jork is to share access to a fixed disk 
that contoins files that are needed by multiple PC users. To accomplish 
this, one PC in the LAfi accepts r-equests from the users' PCs to read and 
SI server 

write records in the shared files. This PC is called the file server, and 
its operation is shown in Figure I. 
C.SP 1 

PC 



PC — Server — Fixed Disk 



PC 

C.SP I 

Figure 1. A File Server 

C.SK 1 
CFO«T 3 5 2 
CFOHT 48 4 1 
CFONT 53 8 1 

Note: This diagram depicU a LAN that uses a star topology. See 
"Connections" in topic 1.2.2 for inforraation about topologies. 
C.SK 2 

SHl.2.1.2 
CTOPlCff 9 
CPARENT 1.2.1 
CFORWAROLEVEL 
CBACKLEVEL 1.2.1.1 

CSUMHARY 1.2.1.2 .SK 1#T5*.SP liTlOf.SP l#T2ff.SK 1#T2«.SK 2 
CHOLEVa :H3 
CSOURCEFM PCLAN 

SI printing 
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EXAMPLE 2 (continued) 

ST Print Servers 
C.SK 1 

Another way to use a local area netv/ork is to share access to a printer. 
To accomplish this, one PC in the LAII accepts requests from the users' Ks 
SI snrver 

to print data on the shared printer. This PC is called the print server, 
CFOMT 38 I 3 
CFONT 40 2 3 
CFOHT 43 3 3 
CFOrJT 47 2 3 
CFOrn 50 1 3 
CFOMT 52 5 3 
CFONT 58 6 3 
CFOHT 55 3 3 
CFONT 69 1 3 
CFOHT 71 4 3 

and its operation is shown below. A PC can be a print server and a file 

CFOfir 3 6 3 

CFOriT 10 14 3 

server simultaneously. 

C.SP I 

PC 



PC — Ser/er — PC 



Printer 



C.SP 1 

Figure 2. A Print Server 

C.SK 1 
CFOKT 3 5 2 
CFONT 48 4 1 
CFOHT 53 6 1 

Hote: This diagram depicts a LAN that uses a star topology. See 
"Connections- in topic 1.2.2 for information about topologies. 

C.SK 2 
SHI. 2. 2 

CTOPICI 10 
CPAREKT 1.2 
CFOWiARDLEVEL 
CBACKLEVEt 1.2.1 

CSUW4ARY 1.2.2 .SK 1#T1#.SK imi.SK \ms.SP UTiei.SP 1IT2#.SP 1 

CHDLEVEL :H2 
CSOURCEFN PCLAN 

SI topology 
ST Connections 

C.SK 1 

Local Area Networks can be connected in two topologies: 
C.SK 1 

SI topology, ring 
SI ring topology 
SI topology, star 

SI Star topology 

\ ring 
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EXAMPLE 2 ( continued ) 



w 



15 



20 



25 



30 



35 



40 



45 



h star 
C.SK 1 

See Figure 3 for an illustration of each. 
C.SP 1 



PC PC 



PC 



PC 



PC Server PC 



PC Server 

C.SP 1 

Figure 3. Ring and Star Topologies 



PC 



C.SP 1 



snmix 

CTOPICff 11 
CPARENT 1.0 

CFOnWAROLEVEL 
CBACKLEVEL i.2 
CSUr4MARy INDEX 113 
CHOLEVEL : INDEX 
CSOURCEFN PCLAN 
ST Index 
CIOELH / 
CGPSEP /P 

CITERI4 /printing/1/1.2.1.2 
CGPSEP /R 

CITERH /ring topology/l/K2,2 
CGPSEP /S 

CITERI4 /server/1/1.2, 1.1/1,2. 1.2 
CITERH /star tope logy/ 1/1.2. 2 
CGPSEP A - 

CITERM /topology/ 1/1, 2.2 
CITERM /ring/2/1.2,2 
CITERH /star/2/1.2.2 
CENDIKDEX 



EXAMPLES 

50 



An example of an array passed from the book display program to to the display interface is shown \r 
This is a piece of the book shown in "Book Data Stream (60) Example" on page 63 
Note: Some of the characters in the anray are unprintable. A pound sign (#) is used as the end attribute 
a donar sign ($) is used as the escape character in this example. 
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*OPTlOilS 


0 9 1 


*ATTRNR 


059 


*ATTR 


1 0 0 2 1 

• www* 


*ATTR 


7 0 0 3 1 


*ATTR 


6 0 0 2 2 


*ATTR 


6 4 0 2 2 


*ATTR 


7 0 0 0 1 


*ATTR 


5 4 0 2 2 


•ATTR 


7 0 0 2 1 


*ATTR 

f 1 1 1 r* 


5 2 0 2 2 








7 D Q P ? 
c u u c c 


•ATTR 


(inn?? 

V V w C ^ 


♦ATTR 


4 4 0 d 1 

f "t U V A 


*ATTR 


d Q Q Q 1 


♦ATTR 


2 2 0 2 2 


♦ATTR 


2 10 2 2 


*ATTB 
n 1 1 1\ 


? ft fl ? 7 

C V w c C 


HI 1 n 


? n ft ? 7 

c w W c c 




5 4 A o ? 

C H U c C 


Ml 1 K 


c fl ft o o 
3 V V ^ c 


n 1 1 K 


c A n 9 7 

3 H U c 4. 


#ATTD 
nl 1 H 


c O O O O 

3 c V c 4 


* A rrn 
HI IK 


1 n ft 5 5 

i U W £ ^ 


• ATTD 
Hi 1 K 


0 n A o 0 
c U u £ c 


HI IK 


1 fl Q 9 9 
J 0 o ^ & 


* ATTD 
Al t K 


J A n o 5 

M U U C C 


*ATTD 
At IK 


A ft ft 5 5 
3 U w c c 


•ATTD 
Hi 1 K 


A A ft 9 7 
O U □ c c 


Ml lit 


7 fl A 7 7 




5 2 Q 2 ? 


Ml 1 n 


*i 7 0 ? 2 
J c u c c 


HI 1 r\ 


1 0 7 7 


♦ATTQ 

Ml 1 n 


A A ft 9 1 

O w O C 


♦ATTB 


7 A f) 7 1 


♦ATTR 
Ml i n 


^ 0 Q 7 1 

^ U w C X 


*ATTD 
nl 1 K 


7 A ft 7 1 
/ V O C 1 


•ATTR 


4 4 0 2 1 


*ATTR 


1 0 0 2 1 


*ATTR 


7 0 0 2 1 


*ATTR 


4 0 0 2 1 


*ATTR 


5 0 0 3 1 


*ATTR 


7 2 0 3 1 


*ATTR 


6 0 0 2 1 


*ATTR 


4 0 0 2 2 


•ATTR 


7 0 0 2 2 


•ATTR 


4 4 0 2 2 


*ATTR 


7 4 0 2 2 



h FKeys 
a Menu 
a Hp2 
d Hp3 
5 Notetnsg 
h Hpl 
c Arrow 
n RfC 

e DANGER 
§ CAUTION 

e V/ARNIN6 
i Cmdlnp 
I Hotelnp 
1 Hp7 
t Hps 
8 Hp9 
A Hp5 
A Hp6 
A Hp4 
A Under 
A TP 

BLUE 

RED 
r PiriK 

CREEH 

TURQUOISE 
T YELLOW 
« WHITE 
A FIND 
5 Reverse 
N Blink 
t Title 
• Message 
j$ Oocumenl 
is Menunolnp 
^ Inpfnoinp 
u Pfknoinp 
u Border 
u Ninpnoinp 
is (4enu normal color 
% Menurev 
' Warning message 

0 PV 
t PK 

1 PVDEF 
t PKOEF 
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EXAMPLE 3 (continued) 

*ATTR 7 0 8 2 2 e XPH 

*ATTR 6 4 0 2 2 I HO 

•ATTR 6 4 0 2 2 i HI 

*ATTR 6 4 0 2 2 I H2 

•ATTR 6 0 0 2 2 i H3 

*ATTR 5 4 0 2 2 » H4 

•AtTR 5 4 0 2 2 : H5 

•ATTR 5 0 0 2 2 / H6 

•ATTR 1 4 0 2 1 0 :H0 

•ATTR "10 0 2 1a MDQUAL 

•ATTR 7 0 0 1 1 b LINEflOTE 

•ESC $ Escape character 

•EATTR a Attribute field END 

+T0PIC 5 0 N 2 1 0 0 065 002 009 079 fl C 
I Local Area Networks connect computers to one another so that PC users can 
share data and software. When two users are connected to a LAN, they 
SaneverSS have to pass floppy disks to each other to share information or 
programs , 

You can also use LANs to share a printer or fixed disk, Soroe LAN systems 
aWtjM two users to $c^stfliultaneous1y$tf update the some database. 

You can even connect LANs to i!;dhosti?e computers! 
+ACTflAR 5 0 N 2 2 0 0 001 004 002 077 N F 

$a Search$a Book parts$a QuerySa Notes$a Exit$a Help $# 
+TITLE 5 0 H 2 2 0 0 003 002 001 079 N F 

Sfl.l Uhat LANs Do Unclassified 

+C0l!^tAHD 7 0 A 2 1 0 0 030 003 001 078 H F 
Command =»> 

+PFS 1 0 P 2 I 0 0 031 003 001 078 M F 

$a Fl=HelpSd F2=ExHelp$a F3=Exit Sa F4-SearchEnip $a F5=Hotes $a F6=Revietf 
+PFS 1 0 P 2 1 0 0 032 003 001 078 N F 

Sa F7=BkwdSa F8«Fwd $a F9=Retrieve $a F10=Actions $a Fll=HelpIndcx $a Fl2<ancel 
4^CURS0R 015 019 

+T0PBORDER 70N211N0OONF 
^UINDOtfl 5 0 N 2 1 1 1 003 002 009 060 R F 

%» *. List all topics with search tfords... %^ 

%is Go to best topic %8 

%:$ •. Go to next best topic $9 

*. Go to next occurrence from this spot in the book %9 

$a 5. Enter new search words... $# 

$a 6. Set search options... $1 

$a Fl«=Help $* $a F12=Cancel $# 
+TOP0ORDER 7 0 N 2 1 I N 000 N F 
mmO\!Z 5 0 N 2 1 1 1 010 085 008 062 R F 

- Enter below the words or phrases to search for, 

- Use connas to separate single words or phrases. 

- Use an asterisk (*) at the end of a word to stand for 
any letter(s). 

Search for $i&Pdinput %9 
$3 Fl°Kelp $d $d F9>Retrieve $e $a F12«Cancel $^ 

+Eor 
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Claims 

5 

1 . A method for creating online books from print oriented source files, comprising the steps of: 
formatting said source file using a print oriented text formatter (20). said print oriented text formatter using 
specially defined online formatting definitions (30). to create a formatted text stream; 

post processing said fonmatted text stream in a text phase (50) to provide a book data stream; 
to post processing pictures in a picture phase (50A) to provide picture information; and 

combining said book data stream and said picture information into a book file (80) having a predetermined 

format 

2. The method according to claim 1 further comprising a method for dynamically displaying online 

books from said book file, said method of displaying comprising the steps of: 

?5 providing display characteristics (100) of a display device on which said book is to be displayed; 

processing said book file and said display device characteristics to provide a book display output stream; 

and 

displaying (130) said book on said display device, 

3. The method according to claim 2 further comprising the steps of storing place information in a first 

20 disk file (140), and storing annotations in a second disk file (150). 
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